Value holding system, value holding method, value holding program, and transaction system

ABSTRACT

With a value holding system comprising a receiving unit that receives an instruction to add or remove a value relating to a payment, a judging unit that judges the instruction is identical with a previously received instruction, and a rejecting unit that rejects the instruction when judged that the instruction is identical with the previous instruction, it is possible to reject an invalid payment request in order to prevent an incorrect collection of payment.

[0001] This application is based on an application NO. 2003-134394 filed in Japan, the content of which is hereby incorporated by reference.

BACKGROUND OF THE INVENTION

[0002] (1) Field of the Invention

[0003] The present invention relates to a value holding system that manages a value used in a payment, and more specifically, it relates to a technique to avoid errors in managing the value.

[0004] (2) Description of the Related Art

[0005] In recent years, memory cards that have multiple functions such as prepaid card and commuter pass functions are utilized in a field of electronic payment. As one example of uses of such memory cards, a railway fare adjustment system using a memory card with prepaid card and commuter pass functionalities is explained below.

[0006] A railway user carries the memory card when taking a train. The user goes through an automatic ticket gate using the memory card when entering and exiting a station. When the user takes a train over a zone specified by the memory card as a commuter pass, information relating to fare adjustment is transmitted between the memory card and the automatic ticket gate. Then, an additional fare is deducted from an amount of prepaid money recorded in the memory card as a prepaid card, and the fare adjustment is completed.

[0007] In order to ensure security, such as mutual authentication and encryption of the information disclosed in a patent document 1, and a verification of the memory card as disclosed in a patent document 2 are performed in the transmission of the information between the memory card and the automatic ticket gate.

[0008] In the transmission of the information, however, an issue has been noted that the automatic ticket gate accidentally requests the memory card for a payment for the same service more than once, the memory card also processes the payment more than once, and thus the amount accidentally requested by the automatic ticket gate is deduced from the memory card. Further, another issue has also been noted that the automatic ticket gate recognizes the zone specified by the memory card incorrectly and requests the memory card for a payment for an additional fare based on the zone incorrectly recognized, and the incorrect additional fare is deducted from the memory card.

[0009] Patent Document 1

[0010] Japanese Published Unexamined Application No. H10-229392

[0011] Patent Document 2

[0012] Japanese Published Examined Application No. H8-27822

SUMMARY OF THE INVENTION

[0013] In view of the above noted issues, the present invention aims to provide a value holding system that avoids incorrect collections.

[0014] A value holding system according to the present invention in order to solve the above noted issues is a value holding system comprising a receiving unit operable to receive an instruction to add or remove a value relating to a payment, a judging unit operable to judge whether the instruction is identical with an instruction that has been previously received, and a rejecting unit operable to reject the instruction when judged that the instruction is identical with the previous instruction.

[0015] By the above construction, the instruction is rejected, when the instruction to add or remove the value is identical with the previous instruction. Accordingly, it is possible to limit the addition or removal of the value to only once, even when the same instruction is received for the second time due to errors in an instruction apparatus.

[0016] The above value holding system may also be such that the value is equivalent to an amount of money, and the receiving unit receives, as the instruction, instruction information that indicates adding or removing the amount of money shown by the value.

[0017] By the above construction, the instruction is rejected, when the instruction to add or remove the value is identical with the previous instruction. Accordingly, it is possible to prevent an incorrect collection by limiting the addition or removal of the amount of money to only once, even when the same instruction is received for the second time due to errors in an instruction apparatus.

[0018] The above value holding system may also be such the judging unit (i) stores a piece of instruction information last received by the receiving unit, and (ii) judges whether the instruction is identical with the previous instruction, using the stored piece of instruction information and the currently received piece of instruction information.

[0019] By the above construction, the judgment whether the instruction is identical with the previous instruction is made, using a piece of instruction information received by the receiving unit this time and a piece of instruction information received by the receiving unit last time. Accordingly, it is possible to prevent an incorrect collection by limiting the addition or removal of the amount of money to only once, even when the same instruction is received for the second time.

[0020] The above value holding system may also be such that the judging unit judges that the instruction is identical with the previous instruction, when the stored piece of instruction information matches the currently received piece of instruction information.

[0021] By the above construction, it is judged that the instruction is identical with the previous instruction, when the stored piece of instruction information matches the received piece of instruction information. Accordingly, it is possible to prevent an incorrect collection by limiting the addition or removal of the value to only once, even when the same instruction is received for the second time.

[0022] The above value holding system may also be such that each instruction information contains an apparatus ID identifying an instruction apparatus, and the judging unit judges that the instruction is identical with the previous instruction, when an apparatus ID contained in the stored piece of instruction information matches an apparatus ID contained in the currently received piece of instruction information.

[0023] By the above construction, it is judged that the instruction is identical with the previous instruction, when the apparatus ID in the stored piece of instruction information matches the apparatus ID in the received piece of instruction information. Accordingly, it is possible to prevent an incorrect collection by limiting the addition or removal of the value to only once, even when the instruction from the same apparatus is received for the second time.

[0024] The above value holding system may also be such that each instruction information contains a location ID identifying a location of an external instruction apparatus, and the judging unit judges that the instruction is identical with the previous instruction, when a location ID contained in the stored piece of instruction information matches a location ID contained in the currently received piece of instruction information.

[0025] By the above construction, it is judged that the instruction is identical with the previous instruction, when the location ID in the stored piece of instruction information matches the location ID in the received piece of instruction information. Accordingly, it is possible to prevent an incorrect collection by limiting the addition or removal of the value to only once, even when the instruction from an apparatus at the same location is received for the second time.

[0026] The above value holding system may also be such that each instruction information contains an instruction ID identifying the instruction information, the judging unit judges that the instruction is identical with the previous instruction, when an instruction ID contained in the stored piece of instruction information matches an instruction ID contained in the currently received piece of instruction information.

[0027] By the above construction, it is judged that the instruction is identical with the previous instruction, when the instruction ID in the stored piece of instruction information matches the instruction ID in the piece of received instruction information. Accordingly, it is possible to prevent an incorrect collection by limiting the addition or removal of the value to only once, even when the same instruction is received for the second time.

[0028] The above value holding system may also be such that the judging unit judges that the instruction is identical with the previous instruction, when a difference between the stored piece of instruction information and currently received piece of instruction information is within a predetermined range.

[0029] By the above construction, it is judged that the instruction is identical with the previous instruction, when the difference between the stored and received pieces of instruction information is within the predetermined range. Accordingly, it is possible to prevent an incorrect collection by limiting the addition or removal of the value to only once, more than one instruction is received successively with its difference less than the predetermined range.

[0030] The above value holding system may also be such that each instruction information contains time information indicating a time relating to the instruction, the judging unit judges that the instruction is identical with the previous instruction, when a difference between a time indicated by time information in the stored piece of instruction information and a time indicated by time information in the currently received piece of instruction information is within a predetermined range.

[0031] By the above construction, it is judged that the instruction is identical with the previous instruction, when the difference between the two pieces of time information in the stored and received pieces of instruction information, respectively, is within the predetermined range. Accordingly, it is possible to prevent an incorrect collection by limiting the addition or removal of the value to only once, even when, due to errors in an instruction apparatus, more than one instruction is received successively in a short period of time.

[0032] The above value holding system may also be structured by a handheld device and a memory card, wherein the handheld device includes the receiving unit, and the memory card includes the judging unit and the rejecting unit.

[0033] By the above construction, the handheld device receives the instruction information, and the memory card detects an instruction identical with the previous instruction based on the instruction information received by the handheld device, and thus, it is possible to prevent an incorrect collection by limiting the addition or removal of the value to only once, even when the same instruction is received for the second time.

[0034] The above value holding system may also be such that the system is a memory card.

[0035] By the above construction, the memory card rejects the instruction from an instruction apparatus when the instruction is identical with the previous instruction, and thus, it is possible to limit the addition or removal of the value to only once, even when more than one instruction is received successively due to errors in the instruction apparatus.

[0036] The above value holding system may also be such that the system is a handheld device.

[0037] By the above construction, the handheld device rejects the instruction from an instruction apparatus when the instruction is identical with the previous instruction, and thus, it is possible to limit the addition or removal of the value to only once, even when more than one instruction is received successively due to errors in the instruction apparatus.

[0038] A method for the above value holding system including a receiving unit, a judging unit, and a rejecting unit, comprises a receiving step in which the receiving unit receives an instruction to add or remove a value relating to a payment, a judging step in which the judging unit judges whether the instruction has been previously received, and a rejecting step in which the rejecting unit rejects the instruction when judged that the instruction has been previously received.

[0039] By the above construction, the instruction is rejected when the instruction from an instruction apparatus is identical with the previous instruction. Accordingly, it is possible to limit the addition or removal of the value to only once, even when more than one instruction is received successively due to errors in the instruction apparatus.

[0040] A program for the above value holding system including a receiving unit, a judging unit, and a rejecting unit, comprises a receiving step in which the receiving unit receives an instruction to add or remove a value relating to a payment, a judging step in which the judging unit judges whether the instruction has been previously received, and a rejecting step in which the rejecting unit rejects the instruction when judged that the instruction has been previously received.

[0041] By the above construction, the instruction is rejected when the instruction from an instruction apparatus is identical with the previous instruction. Accordingly, it is possible to limit the addition or removal of the value to only once, even when more than one instruction is received successively due to errors in the instruction apparatus.

[0042] A transaction system according to the present invention is structured by an instruction apparatus and the above value holding system comprising a receiving unit operable to receive an instruction to add or remove a value relating to a payment, a judging unit operable to judge whether the instruction is identical with an instruction that has been previously received, and a rejecting unit operable to reject the instruction when judged that the instruction is identical with the previous instruction.

[0043] By the above construction, the instruction is rejected when the instruction from an instruction apparatus is identical with the previous instruction. Accordingly, it is possible to limit the addition or removal of the value to only once, even when more than one instruction is received successively due to errors in the instruction apparatus.

[0044] The above transaction system may also be such that the value holding system is a memory card.

[0045] By the above construction, the instruction is rejected when the instruction from an instruction apparatus is identical with the previous instruction. Accordingly, it is possible to limit the addition or removal of the value to only once, even when more than one instruction is received successively due to errors in the instruction apparatus.

[0046] The above transaction system may also be such that the value holding system is a handheld device.

[0047] By the above construction, the instruction is rejected when the instruction from an instruction apparatus is identical with the previous instruction. Accordingly, it is possible to limit the addition or removal of the value to only once, even when more than one instruction is received successively due to errors in the instruction apparatus.

[0048] The above transaction system may also be such that the value holding system is structured by a handheld device and a memory card, the handheld device including the receiving unit, and the memory card including the judging unit and the rejecting unit.

[0049] By the above construction, the handheld device receives the instruction information, and the memory card detects an instruction identical with the previous instruction based on the instruction information received by the handheld device, and thus, it is possible to limit the addition or removal of the value to only once, even when the same instruction is received for the second time.

[0050] The above value holding system may also be such that the value is equivalent to an amount of points, and the receiving unit receives, as the instruction, instruction information that indicates adding or removing the amount of points shown by the value.

[0051] By the above construction, the instruction is rejected, when the instruction to add or remove the value indicating the points is identical with the previously received instruction. Accordingly, it is possible to prevent an incorrect addition or removal of points by limiting the addition or removal of the amount of points to only once, even when the same instruction is received for the second time due to errors in an instruction apparatus.

BRIEF DESCRIPTION OF THE DRAWINGS

[0052] These and the other objects, advantages and features of the invention will become apparent from the following description thereof taken in conjunction with the accompanying drawings which illustrate a specific embodiment of the invention.

[0053] In the drawings:

[0054]FIG. 1 illustrates a structure of a fare adjustment system in a railway company;

[0055]FIG. 2 is a block diagram illustrating a structure of a memory card;

[0056]FIG. 3 is a block diagram illustrating a structure of an automatic ticket gate;

[0057]FIG. 4 is a flowchart showing an entire transaction of fare adjustment;

[0058]FIG. 5 is a flowchart showing an operation of mutual authentication of devices and sharing of a key;

[0059]FIG. 6 is a flowchart showing another operation of mutual authentication of devices and sharing of a key;

[0060]FIG. 7 is a flowchart showing an operation of checking of contents of a payment request;

[0061]FIG. 8 illustrates a structure of a transaction system;

[0062]FIG. 9 is a block diagram illustrating a structure of a memory card;

[0063]FIG. 10 is a block diagram illustrating a structure of a cash register; and

[0064]FIG. 11 is a flowchart showing an entire transaction.

DESCRIPTION OF THE PREFERRED EMBODIMENT

[0065] The following describes preferred embodiments of the present invention with reference to the drawings. A term “service” in the specification is a concept including sales.

[0066] First Embodiment

[0067] 1-1 Structure

[0068] A value holding system 1 of First Embodiment according to the present invention is explained below in reference to drawings.

[0069]FIG. 1 illustrates a structure of the value holding system 1 in a railway company. A user 10 travels from a boarding station 11 to a destination station 13 by taking a train 12.

[0070] Each of the boarding station 11, the destination station 13, and other stations (not shown in the drawing) that are provided by the railway company is assigned, in advance, with unique station ID information for identifying the station. Further, at least one automatic ticket gate as an instruction apparatus is provided to each station. Each automatic ticket gate has a flap door, and stores the station ID information of the station to which the automatic ticket gate is provided and unique gate ID information for identifying the automatic ticket gate. In the present embodiment, an automatic ticket gate 300 is provided to the boarding station 11, and an automatic ticket gate 200 is provided to the destination station 13.

[0071] A memory card 100 is a payment processing device, which is a contactless memory card with prepaid card and commuter pass functionalities and issued by the railway company. The user 10 obtains the memory card 100 from the railway company in an exchange for a predetermined amount of payment.

[0072] The user 10 carries the memory card 100 when taking the train 12.

[0073] When the user 10 attempts to go through the automatic ticket gate 300 and enter the boarding station 11 in order to take the train 12, the user 10 holds the memory card 100 toward the automatic ticket gate 300. Information is transmitted wirelessly between the memory card 100 and the automatic ticket gate 300, and the flap door of the automatic ticket gate 300 opens if the automatic ticket gate 300 judges that the user 10 is allowed to enter based on the transmitted information. The user 10 enters the boarding station 11 after the flap door is open. The user 10 then takes the train 12 and travels from the boarding station 11 to the destination station 13.

[0074] At the destination station 13, when the user 10 attempts to go through the automatic ticket gate 200 and exit the destination station 13, the user 10 holds the memory card 100 toward the automatic ticket gate 200. Information is transmitted wirelessly between the memory card 100 and the automatic ticket gate 200, and the flap door of the automatic ticket gate 200 opens if the automatic ticket gate 200 judges that the user 10 is allowed to exit based on the transmitted information.

[0075] When the user 10 takes the train 12 over a zone specified by the memory card 100 as a commuter pass, an additional fare is charged. The additional fare is adjusted using the prepaid card functionality of the memory card 100.

[0076] An operation for the fare adjustment is detailed below.

[0077] 1-1-1 Memory Card 100

[0078] The memory card 100 as hardware is structured by a CPU, a ROM storing a computer program, a RAM, and such. The memory card 100 realizes its function by the CPU operating according to the program stored in the ROM. FIG. 2 is a block diagram illustrating a structure of the memory card 100.

[0079] [Communication Unit 101]

[0080] A communication unit 101 transmits and receives information wirelessly with the automatic ticket gate 200.

[0081] [Authentication Unit 102]

[0082] An authentication unit 102 performs mutual authentication and sharing of a key with the automatic ticket gate 200 via the communication unit 101. Details of the mutual authentication and the sharing of the key will be described later.

[0083] When the mutual authentication and the sharing of the key are successfully completed, the authentication unit 102 transmits an authentication completion notification to a pass information management unit 104 and a card ID information management unit 105.

[0084] [Encryption Unit 103]

[0085] An encryption unit 103 encrypts and decrypts the information transmitted between the communication unit 101 and the automatic ticket gate 200.

[0086] When the mutual authentication and the sharing of the key are successfully completed, the encryption unit 103 obtains a session key K′ from the authentication unit 102. In the transmission of the information to the automatic ticket gate 200 after the successful completion of the mutual authentication and the sharing of the key, the encryption unit 103 encrypts the information to be transmitted using the session key K′, and then the communication unit 101 transmits the encrypted information. Further, information that the communication unit 101 received from the automatic ticket gate 200 after the successful completion of the mutual authentication and the sharing of the key is used for an internal process of the memory card 100 after the encryption unit 103 decrypts the received information using the session key K′.

[0087] In order to keep the description simple, encryption of information before transmitting the information is always included in an operation described by such wordings as “transmit the information via the communication unit 101′. Therefore, such wordings indicate that the encryption unit 103 encrypts the information to be transmitted and then the communication unit 101 transmits the encrypted information. Similarly, decryption of information after receiving the information is always included in an operation described by such wordings as “receive the information via the communication unit 101”. Therefore, such wordings indicate that the communication unit 101 receives the information and then the encryption unit 103 decrypts the received information.

[0088] [Pass Information Management Unit 104]

[0089] The pass information management unit 104 stores and manages valid zone information indicating a zone within which the memory card as a commuter pass is valid. The valid zone information is made of zone start information and zone end information. The pass information management unit 104, after receiving the authentication completion notification, receives boarding station information from the automatic ticket gate 300 at the boarding station 11, and stores the boarding station information. The boarding station information indicates station ID information corresponding to the boarding station 11. The pass information management unit 104 also receives destination station information from the automatic ticket gate 200 at the destination station 13, when the user 10 attempts to exit the station. The destination station information indicates station ID information corresponding to the destination station 13. All of the zone start information, zone end information, boarding station information, and destination station information are predetermined integer.

[0090] Upon reception of the destination station information, the pass information management unit 104 judges if the user 10 has taken the train 12 within or over the zone specified by the valid zone information, based on the zone start information, zone end information, boarding station information, and destination station information. When both of the boarding station information and destination station information are equal to or between the zone start information and zone end information, the pass information management unit 104 judges that the user 10 has taken the train 12 within the zone in which the memory card as the commuter pass is valid, i.e. “in-zone”. When either of the boarding station information and destination station information is smaller than the zone start information or larger than the zone end information, the pass information management unit 104 judges that the user 10 has taken the train 12 over the zone in which the memory card as the commuter pass is valid, i.e. “out-zone”.

[0091] A more specific explanation is given below, taking a case in which the zone start information is 10 and the zone end information is 20, for example. In this case, if the station information for the boarding station 11 is 12, and the station information for the destination station 13 is 15, then the pass information management unit 104 judges that the user 10 has taken the train 12 within the zone. If the station information for the boarding station 11 is 12, but the station information for the destination station 13 is 22, then the pass information management unit 104 judges that the user 10 has taken the train 12 over the zone.

[0092] When the judging is that the user 10 has taken the train 12 within the zone, the pass information management unit 104 transmits, to a payment management unit 108, boarding zone information indicating “in-zone”. When the judging is that the user 10 has taken the train 12 over the zone, the pass information management unit 104 transmits, to the payment management unit 108, the boarding zone information indicating “out-zone”.

[0093] Further, when receiving the authentication completion notification from the authentication unit 102, the pass information management unit 104 transmits the valid zone information and boarding station information to the automatic ticket gate 200 via the communication unit 101.

[0094] [Card ID Information Management Unit 105]

[0095] The card ID information management unit 105 stores unique card ID information for identifying the memory card.

[0096] The card ID information management unit 105 receives the authentication completion notification from the authentication unit 102. When the authentication completion notification is received, the card ID information management unit 105 transmits the card ID information to the automatic ticket gate 200 via the communication unit 101.

[0097] The card ID information management unit 105 also receives card specifying information from the automatic ticket gate 200 via the communication unit 101. The card specifying information indicates the card ID information of a card which the automatic ticket gate 200 recognizes as a billing card. When the card specifying information is received, the card ID information management unit 105 judges if the transmitted card ID information and the received card specifying information are identical.

[0098] When the transmitted card ID information and the received card specifying information are identical, the card ID information management unit 105 transmits communication information indicating successful communication to the payment management unit 108. When the transmitted card ID information and the received card specifying information are not identical, it indicates that the card ID information management unit 105 received a payment request for a different memory card, and the card ID information management unit 105 transmits communication information indicating communication error to the payment management unit 108.

[0099] [Ticket Gate Management Unit 106]

[0100] A ticket gate management unit 106 receives the gate ID information from the automatic ticket gate 200 via the communication unit 101.

[0101] The ticket gate management unit 106 stores previously received gate ID information as ticket gate history. Contents of the ticket gate history are deleted when the pass information management unit receives the boarding station information.

[0102] When the gate ID information is received, the ticket gate management unit 106 judges if the gate ID information and the ticket gate history are identical.

[0103] When the gate ID information matches the ticket gate history, the ticket gate management unit 106 judges that the memory card 100 successively communicates with the same automatic ticket gate, and transmits the communication information indicating communication error to the payment management unit 108. When the gate ID information and the ticket gate history are not identical, the ticket gate management unit 106 transmits the communication information indicating successful communication to the payment management unit 108.

[0104] [Time Information Management Unit 107]

[0105] A time information management unit 107 stores valid period information indicating a period during which the memory card as the commuter pass is effective. The valid period information is made of period start information indicating an earliest time when the user is allowed to use the card, and period end information indicating a last time when the user is allowed to use the card. In a case in which the earliest time when the user is allowed to use the card is 12:10'30, Feb. 10, 2003, the period start information is 20030210121030, and the last time when the user is allowed to use the card is 12:10'30, Mar. 10, 2003, the period end information is 20030310121030.

[0106] When the user 10 attempts to exit the destination station 13, the time information management unit 107 receives gate time information from the automatic ticket gate 200 at the destination station 13. The gate time information indicates date and hour when the mutual authentication and sharing of the key is completed. The gate time information is also in the same format as the period start information and period end information.

[0107] The time information management unit 107 stores the previously received gate time information as gate time history.

[0108] Upon reception of the gate time information, the time information management unit 107 judges if the user 10 has taken the train 12 within or over the period specified by the valid period information, based on the valid period information and gate time information. When the gate time information is equal to or between the period start information and the period end information, the time information management unit 107 judges that the user 10 has taken the train 12 during the period in which the memory card as the commuter pass is valid, i.e. “in-period”. When the gate time information is smaller than the period start information or larger than the period end information, the time information management unit 107 judges that the user 10 has taken the train 12 not during the period in which the memory card as the commuter pass is valid, i.e. “out-period”.

[0109] When the judging is that the user 10 has taken the train 12 during the period in which the memory card as the commuter pass is valid, the time information management unit 107 transmits, to the payment management unit 108, boarding period information indicating “in-period”. When the judging is that the user 10 has taken the train 12 not during the period in which the memory card as the commuter pass is valid, the time information management unit 107 transmits, to the payment management unit 108, boarding period information indicating “out-period”, and further judges if a difference between the gate time information and the gate time history is 5 seconds or smaller.

[0110] When the judging of the difference is 5 seconds or smaller, the time information management unit 107 judges that the memory card 100 successively communicates with the same automatic ticket gate due to an error at the automatic ticket gate 200, and transmits operation information indicating an operation error to the payment management unit 108. When the judging of the difference is larger than 5 seconds, the time information management unit 107 transmits the operation information indicating a normal operation to the payment management unit 108.

[0111] [Payment Management Unit 108]

[0112] The payment management unit 108 receives the boarding zone information from the pass information management unit 104, the communication information from each of the card ID information management unit 105 and the ticket gate management unit 106, and the boarding period information and operation information from the time information management unit 107. The payment management unit 108 is also operable to transmit payment status information indicating one of “payable”, “unpayable”, and “invalid” to the automatic ticket gate 200 via the communication unit 101.

[0113] If the automatic ticket gate has requested the memory card for a payment in a case in which the communication information indicates the communication error or the operation information indicates the operation error, the payment management unit 108 transmits the payment status information indicating invalid to the automatic ticket gate 200 via the communication unit 101. Further, if the automatic ticket gate has requested the memory card for the payment when the boarding zone information and the boarding period information respectively indicate “in-zone” and “in-period”, the payment management unit 108 transmits the payment status information indicating invalid to the automatic ticket gate 200 via the communication unit 101.

[0114] When the payment management unit 108 judges that the payment request is valid based on all of the received information, the payment management unit 108 transmits a request for payment ability information to a balance management unit 109.

[0115] When the payment management unit 108 receives, from the balance management unit 109, the payment ability information indicating “payable”, the payment management unit 108 transmits the payment status information indicating “payable” to the automatic ticket gate 200 via the communication unit 101. When the received payment ability information indicates 37 unpayable”, the payment management unit 108 transmits the payment status information indicating “unpayable” to the automatic ticket gate 200 via the communication unit 101.

[0116] [Balance Management Unit 109]

[0117] The balance management unit 109 stores balance information indicating an amount of money that is recorded in the memory card as the prepaid card. An additional explanation about the prepaid card functionality is given below.

[0118] The user 10 pays to the railway company in advance for an amount to be recorded in the memory card as the prepaid card. The railway company adds the prepaid amount to the amount indicated by the balance information.

[0119] When the user 10 takes the train 12 over the zone specified by the valid zone information, the balance management unit 109 receives additional fare information from the automatic ticket gate 200 via the communication unit 101. The additional fare information indicates an amount of additional fare for taking the train 12 over the zone. Further, the balance management unit 109 receives the request for the payment ability information from the payment management unit 108.

[0120] When the request for the payment ability information is received, the balance management unit 109 judges if the amount indicated by the additional fare information is payable with the amount of money indicated by the balance information.

[0121] When the amount indicated by the additional fare information is equal to or smaller than the amount indicated by the balance information, the balance management unit 109 judges that the additional fare is “payable”. When the amount indicated by the additional fare information is greater than the amount indicated by the balance information, the balance management unit 109 judges that the additional fare is “unpayable”.

[0122] When the additional fare is judged to be “payable”, the balance management unit 109 transmits the payment ability information indicating “payable” to the payment management unit 108. When the additional fare is judged to be “unpayable”, the balance management unit 109 transmits the payment ability information indicating “unpayable” to the payment management unit 108.

[0123] The balance management unit 109 also receives a payment instruction from the automatic ticket gate 200 via the communication unit 101. Upon reception of the payment instruction, the balance management unit 109 deducts the amount indicated by the additional fare information from the amount indicated by the balance information, and stores an amount after the deduction as new balance information. The balance management unit 109 then transmits a paid notification to the automatic ticket gate 200 via the communication unit 101.

[0124] 1-1-2 Automatic Ticket Gate 200

[0125] The automatic ticket gate 200 as hardware is structured by a CPU, a ROM storing a computer program, a RAM, and such. The automatic ticket gate 200 realizes its function by the CPU operating according to the program stored in the ROM. FIG. 3 is a block diagram illustrating a structure of the automatic ticket gate 200.

[0126] [Communication Unit 201]

[0127] A communication unit 201 transmits and receives information wirelessly with the memory card 100.

[0128] [Authentication Unit 202]

[0129] An authentication unit 202 performs the mutual authentication and the sharing of the key with the memory card 100 via the communication unit 201. Details of the mutual authentication and the sharing of the key will be described later.

[0130] When the mutual authentication and the sharing of the key are successfully completed, the authentication unit 202 transmits an authentication completion notification to a gate information management unit 204 and a clock unit 205.

[0131] [Encryption Unit 203]

[0132] An encryption unit 203 encrypts and decrypts the information transmitted between the communication unit 201 and the memory card 100.

[0133] When the mutual authentication and the sharing of the key are successfully completed, the encryption unit 203 obtains a session key K from the authentication unit 202. In the transmission of the information to the memory card 100 after the successful completion of the mutual authentication and the sharing of the key, the encryption unit 203 encrypts the information to be transmitted using the session key K, and then the communication unit 201 transmits the encrypted information. Further, information that the communication unit 201 received from the memory card 100 after the successful completion of the mutual authentication and the sharing of the key is used for an internal process of the automatic ticket gate 200 after the encryption unit 203 decrypts the received information using the session key K.

[0134] After the mutual authentication and the sharing of the key are successfully completed, the communication between the memory card 100 and the automatic ticket gate 200 is performed always using the encrypted information as described above. In order to keep the description simple, encryption of information before transmitting the information is always included in an operation described by such wordings as “transmit the information via the communication unit 201”. Therefore, such wordings indicate that the encryption unit 203 encrypts the information to be transmitted and then the communication unit 201 transmits the encrypted information. Similarly, decryption of information after receiving the information is always included in an operation described by such wordings as “receive the information via the communication unit 201”. Therefore, such wordings indicate that the communication unit 201 receives the information and then the encryption unit 203 decrypts the received information.

[0135] [Gate Information Management Unit 204]

[0136] A gate information management unit 204 stores the station ID information and the gate ID information in advance. Upon reception of the authentication completion notification from the authentication unit 202, the gate information management unit 204 transmits the station ID information and the gate ID information to the memory card 100 via the communication unit 201.

[0137] [Clock Unit 205]

[0138] A clock unit 205 is a clock to keep time. Upon reception of the authentication completion notification from the authentication unit 202, the clock unit 205 transmits the gate time information indicating time when the authentication completion notification is received to the memory card 100 via the communication unit 201.

[0139] [Payment Request Unit 206]

[0140] A payment request unit 206 transmits the additional fare information to the memory card 100.

[0141] The payment request unit 206 stores a fare table in advance, which indicates a fare between any pair of stations indicated by a different piece of station ID information. The fare table is a table in which the fare and two pieces of the station ID information for the pair of stations correspond to each other. The station ID information and the fare are integers. The fare table includes, for example, three numbers 3, 10, and 200, that correspond to each other, which indicates that the fare is 200 yen when the user takes a train from a station whose station ID information is 3 to another station whose station ID information is 10.

[0142] The payment request unit 206 receives the valid zone information, valid period information, and boarding station information from the memory card 100. The payment request unit 206 judges if the date and hour indicated by the gate time information are within the period indicated by the valid period information.

[0143] If the payment request unit 206 judges that the date and hour indicated by the gate time information are not within the period indicated by the valid period information, the payment request unit 206 transmits, to the memory card 100 via the communication unit 201, the additional fare information indicating the fare between the stations indicated by the boarding station information and destination station information.

[0144] If the payment request unit 206 judges that the date and hour indicated by the gate time information are within the period indicated by the valid period information, the payment request unit 206 judges if the station ID information is over the zone, using the station ID stored in the information gate information management unit 204 and the valid zone information.

[0145] When the payment request unit 206 judges that the station ID information is over the zone, the payment request unit 206 calculates an amount to be paid by the user 10 based on the fare table, and transmits, to the memory card 100 via the communication unit 201, the additional fare information corresponding to the calculated amount.

[0146] Further, when the payment request unit 206 judges that the station ID information is within the zone, the payment request unit 206 transmit a gate opening instruction to a gate control unit 207.

[0147] [Gate Control Unit 207]

[0148] The gate control unit 207 controls gating of the flap door.

[0149] The gate control unit 207 receives one of the gate opening instruction from the payment request unit 206 and a gate closing instruction from a payment management unit 208. If the door is closed when the gate opening instruction is received, the gate control unit 207 opens the flap door. If the door is open when the gate closing instruction is received, the gate control unit 207 closes the flap door.

[0150] [Payment Management Unit 208]

[0151] The payment management unit 208 receives, from the memory card 100, the payment status information that indicates one of “payable”, “unpayable, and “invalid”.

[0152] When the payment status information indicates payable, the payment management unit 208 transmits the payment instruction to the memory card 100 via the communication unit 201. When the payment status information indicates unpayable, the payment management unit 208 transmits the gate closing instruction to the gate control unit 207.

[0153] When the payment status information indicates invalid, the payment management unit 208 finishes the operation.

[0154] 1-2 Operation

[0155]FIG. 4 is a flowchart showing an entire transaction of the fare adjustment.

[0156] The memory card 100 and the automatic ticket gate 200 perform the mutual authentication and the sharing of the key (Step S101).

[0157] The mutual authentication and the sharing of the key between the authentication unit 202 of the automatic ticket gate 200 and the authentication unit 102 of the memory card 100 is explained in detail with reference to flowcharts in FIGS. 5 and 6.

[0158] The authentication unit 202 of the automatic ticket gate 200 records a public key PK-CA, a secret key SK-A, and a public key certification Cert-A issued by a Certificate Authority (CA) in advance, and includes an encrypting unit that uses an elliptic curve E. The authentication unit 102 of the memory card 100 records the public key PK-CA, a secret key SK-i, and the public key certification Cert-i issued by a Certificate Authority (CA) in advance, and also includes an encrypting unit that uses the elliptic curve E.

[0159] “Sig(SK,D)” is an equation used for calculation to apply a digital signature, using the secret key SK. “G” is a base point on the elliptic curve E, and a unique value for this authentication system. “*” is an operator that indicates a multiplication on the elliptic curve E. For example, “x*G” is an equation for adding the point G on the elliptic curve E for x number of times. “∥” is an operator that indicates a join. For example, “A∥B” shows a result of joining of A and B.

[0160] Wordings such as “the authentication unit 202 outputs the information to the authentication unit 102” and “the authentication unit 102 outputs the information to the authentication unit 202” are simplified description, and these wordings mean “the authentication unit 202 outputs the information to the authentication unit 102 via the communication unit 201 and communication unit 101” and “the authentication unit 102 outputs the information to the authentication unit 202 via the communication unit 101 and communication unit 201”, respectively.

[0161] The authentication unit 102 generates a random number y (Step S201), and outputs the generated random number y and the public key certification Cert-i to the authentication unit 202 (Step S202).

[0162] The authentication unit 202 receives the random number y and the public key certification Cert-i (Step S202), and checks if the public key certification Cert-i of the memory card 100 has been revoked, using a Certificate Revocation List (CRL) (Step S203). If the public key certification Cert-i has been revoked (Step S204), the operation ends.

[0163] If the public key certification Cert-i is not revoked (Step S204), the authentication unit 202 verifies the public key certification Cert-i using the public key PK-CA (Step S205). If the verification is not successful (Step S206), the authentication unit 202 finishes the operation.

[0164] If the verification is successful (Step S206), the authentication unit 202 generates a random number x (Step S207), and outputs the generated random number x and the public key certification Cert-A to the authentication unit 102 (Step S208).

[0165] The authentication unit 102 receives the random number x and the public key certification Cert-A from the authentication unit 202 (Step S208). Next, the authentication unit 102 checks if the public key certification Cert-A of the automatic ticket gate 200 has been revoked, using the CRL (Step S209). If the public key certification Cert-A has been revoked (Step S210), the operation ends.

[0166] If the public key certification Cert-A is not revoked (Step S210), the authentication unit 102 verifies the public key certification Cert-A using the public key PK-CA (Step S211). If the verification is not successful (Step S212), the authentication unit 102 finishes the operation.

[0167] If the verification is successful (Step S212), the authentication unit 102 generates a random number y′ (Step S213), generates a signature data S1=Sig(SK-i, (y′*G)∥x) (Step S214), and outputs y′*G and S1 to the authentication unit 202 (Step S215). The authentication unit 202 receives y′*G and S1 from the authentication unit 102 (Step S215). Then the authentication unit 202 verifies S1 (Step S216). If the verification is not successful (Step S217), the authentication unit 202 finishes the operation.

[0168] If the verification is successful (Step S217), the authentication unit 202 generates a random number x′ (Step S218), generates a signature data S0=Sig(SK-A, (x′*G)∥y) (Step S219), and outputs x′*G and S0 to the authentication unit 102 (Step S220).

[0169] The authentication unit 102 receives x′*G and S0 from the authentication unit 202 (Step S220). Next, the authentication unit 102 verifies S0 (Step S221). If the verification is not successful (Step S222), the authentication unit 102 finishes the operation.

[0170] If the verification is successful (Step S222), the authentication unit 102 calculates the session key K′=y′ (x′*G) (Step S223).

[0171] On the other hand, the authentication unit 202 calculates the session key K=x′(y′*G) (Step S224).

[0172] In this way, the mutual authentication and the sharing of the key between the automatic ticket gate 200 and the memory card 100 are performed.

[0173] The session key K and K′ are keys having a shared value between the automatic ticket gate 200 and the memory card 100, respectively.

[0174] When the authentication of Step S101 is successful, the memory card 100 transmits the valid zone information, valid period information, card ID information, and boarding station information to the automatic ticket gate 200 (Step S102).

[0175] Further, when the authentication of Step S101 is successful, the automatic ticket gate 200 transmits the destination station information, gate ID information, and gate time information to the memory card 100 (Step S103).

[0176] The automatic ticket gate 200 judges if it is necessary to charge the additional fare, based on the received zone information, valid period information, and boarding station information (Step S104). The operation proceeds to Step S113 if the automatic ticket gate 200 judges that it is not necessary to charge the additional fare.

[0177] If the automatic ticket gate 200 judges that it is necessary to charge the additional fare, the automatic ticket gate 200 transmits the additional fare information and card specifying information to the memory card 100 to request the memory card 100 for the payment (Step S105). The memory card 100 receives the additional fare information and card specifying information and checks contents of the payment request (Step S106).

[0178]FIG. 7 is a flowchart explaining the operation of Step S106 in detail.

[0179] The card ID information management unit 105 judges if the card specifying information matches the card ID information (Step S301). When the card ID information management unit 105 judges that the card specifying information does not match the card ID information, the operation proceeds to Step S309. When the card ID information management unit 105 judges that the card specifying information matches the card ID information, the operation proceeds to Step S302.

[0180] The ticket gate management unit 106 judges if the gate ID information matches the ticket gate history (Step S302). When the ticket gate management unit 106 judges that the gate ID information matches the ticket gate history, the operation proceeds to Step S309. When the ticket gate management unit 106 judges that the gate ID information does not match the ticket gate history, the operation proceeds to Step S303.

[0181] The time information management unit 107 judges if the difference between the gate time information and the gate time history is 5 seconds or smaller (Step S303). When the time information management unit 107 judges that the difference between the gate time information and the gate time history is 5 seconds or smaller, the operation proceeds to Step S309. When the time information management unit 107 judges that the difference between the gate time information and the gate time history is greater than 5 seconds, the operation proceeds to Step S304.

[0182] The pass information management unit 104 judges if the station ID information is within or over the zone specified by the valid zone information (Step S304). When the pass information management unit 104 judges that the station ID information is within the zone, the pass information management unit 104 further judges if the user 10 has taken the train 12 within or over the period specified by the valid period information (Step S305). When the pass information management unit 104 judges the user 10 has taken the train 12 within the period in Step S305, the operation proceeds to Step S306. When the pass information management unit 104 judges the user 10 has taken the train 12 over the period in Step S305, the operation proceeds to Step S309. When the pass information management unit 104 judges that the station ID information is over the zone in Step S304, the operation proceeds to Step S306.

[0183] The balance management unit 109 judges if the additional fare is payable or unpayable (Step S306). When the balance management unit 109 judges that the additional fare is larger than the amount remaining in the card, the operation proceeds to Step S308. When the balance management unit 109 judges that the additional fare is equal to or smaller than the amount remaining in the card, the operation proceeds to Step S307.

[0184] The memory card 100 generates the payment status information indicating payable (Step S307).

[0185] The memory card 100 generates the payment status information indicating unpayable (Step S308).

[0186] The memory card 100 generates the payment status information indicating invalid (Step S309).

[0187] The memory card 100 transmits the generated payment status information to the automatic ticket gate 200 (Step S107).

[0188] The automatic ticket gate 200 receives the payment status information (Step S108).

[0189] When the received payment status information indicates invalid, the automatic ticket gate 200 finishes the operation. When the received payment status information indicates unpayable, the operation proceeds to Step S112. When the received payment status information indicates payable, the automatic ticket gate 200 transmits the payment instruction to the memory card 100 (Step S109).

[0190] The memory card 100 receives the payment instruction (Step S110). The memory card 100 deducts the additional fare from the balance information. The memory card 100 transmits the paid notification to the automatic ticket gate 200 (Step S111).

[0191] The automatic ticket gate 200 closes the flap door provided thereto, and finishes the operation (Step S112).

[0192] The automatic ticket gate 200 opens the flap door provided thereto, and finishes the operation (Step S113).

[0193] Second Embodiment

[0194] 2-1 Structure

[0195] A value holding system 2 of Second Embodiment according to the present invention is explained below in reference to drawings. FIG. 8 illustrates a structure of the value holding system 2.

[0196] A user 50 carries a memory card 500 when shopping in a shop 60. The memory card 500 is a contactless memory card with prepaid card functionality issued by a company that runs the shop 60.

[0197] The user 50 brings an article to be purchased to a checkout counter of the shop 60. A cash register 600 is placed at the checkout counter, and a cashier 70 operates the cash register 600. The cash register 600 stores register ID information for identifying the cash register.

[0198] The cashier 70 has a barcode reader provided to the cash register 600 read a barcode attached to the article. Then, the cashier 70 presses a calculation button provided to the cash register 600.

[0199] The cash register 600 calculates an amount of money to be paid by the user 50 in exchange of the article. The cash register 600 wirelessly transmits, to the memory card 500, instruction information indicating a payment request for the calculated amount of money.

[0200] The memory card 500 performs a payment operation of the calculated amount of money based on the received instruction information, using the prepaid card functionality. In the payment operation, the memory card 500 rejects the payment request in a case in which the payment request for the amount of money, which is transmitted to the memory card 500 from the cash register, is identical with a previous payment request.

[0201] The payment processing operation is detailed below.

[0202] 2-1-1 Memory Card 500

[0203] The memory card 500 as hardware is structured by a CPU, a ROM storing a computer program, a RAM, and such. The memory card 500 realizes its function by the CPU operating according to the program stored in the ROM. FIG. 9 is a block diagram illustrating a structure of the memory card 500.

[0204] [Communication Unit 501]

[0205] The communication unit 501 transmits and receives information wirelessly with the cash register 600.

[0206] [Authentication Unit 502]

[0207] An authentication unit 502 performs mutual authentication and sharing of a key with the cash register 600 via the communication unit 501. The mutual authentication and the sharing of the key are the same operation as in Step S101 explained above, and not detailed here.

[0208] The operation of the mutual authentication and the sharing of the key may also be described by FIG. 5 by replacing the automatic ticket gate 200 with the cash register 600 and the memory card 100 with the memory card 500.

[0209] When the mutual authentication and the sharing of the key are successfully completed, the authentication unit 502 transmits an authentication completion notification to a card ID information management unit 504.

[0210] [Encryption Unit 503]

[0211] An encryption unit 503 encrypts and decrypts the information transmitted.

[0212] When the mutual authentication and the sharing of the key are successfully completed, the encryption unit 503 obtains a session key K′ from the authentication unit 502.

[0213] After the successful completion of the mutual authentication and the sharing of the key by the authentication unit 502, the communication between the memory card 500 and the cash register 600 is always performed with the information being encrypted. In the transmission of the information to the cash register 600 after the successful completion of the mutual authentication and the sharing of the key, first the encryption unit 503 encrypts the information to be transmitted using the session key K′, and then the communication unit 501 transmits the encrypted information. Further, information that the communication unit 501 received from the cash register 600 after the successful completion of the mutual authentication and the sharing of the key is used for an internal process of the memory card 500 after the encryption unit 503 decrypts the received information using the session key K′.

[0214] [Card ID Information Management Unit 504]

[0215] The card ID information management unit 504 stores unique card ID information for identifying the memory card.

[0216] The card ID information management unit 504 receives the authentication completion notification from the authentication unit 502. When the authentication completion notification is received, the card ID information management unit 504 transmits the card ID information to the cash register 600 via the communication unit 501.

[0217] The card ID information management unit 504 also receives card specifying information from the cash register 600 via the communication unit 501. The card specifying information is card ID information indicating a card which the cash register 600 recognizes as a billing card. When the card specifying information is received, the card ID information management unit 504 judges if the transmitted card ID information and the received card specifying information are identical.

[0218] When the transmitted card ID information and the received card specifying information are identical, the card ID information management unit 504 transmits a judgment instruction to an information management unit 505. When the transmitted card ID information and the received card specifying information are not identical, it indicates that the card ID information management unit 504 received instruction information for a different memory card, and the card ID information management unit 504 transmits payment status information indicating invalid to the cash register 600 via the communication unit 501. The payment status information indicates one of “invalid”, “paid”, and “unpayable”.

[0219] [Information Management Unit 505]

[0220] The information management unit 505 receives the register ID information, instruction ID information, request time information, and the amount of money to be paid, from the cash register 600 via the communication unit 501. The instruction ID information is for specifying the instruction information. The request time information indicates time at which a clock in the cash register 600 records when the transmission of the instruction information starts.

[0221] When the judgment instruction is received from the card ID information management unit 504, the information management unit 505 judges if the payment request indicated by the instruction information is identical with the previous payment request, based on the register ID information, instruction ID information, and request time information.

[0222] For example, when the user 50 purchases a piece of bread that is 200 yen, the cash register 600 transmits the instruction information to request the memory card 500 for a payment of 200 yen as an amount of money to be paid, according to the operation by the cashier 70. The instruction information here is a valid payment request. The memory card 500 deducts 200 yen from the amount of money managed by a balance management unit 506.

[0223] After the deduction has been completed, if the cash register 600 accidentally transmits the same instruction information about the piece of bread to the memory card 500, the memory card judges that the payment request is identical with the previous payment request.

[0224] An explanation about the judgment performed by the information management unit 505 is given below.

[0225] The information management unit 505 stores previously received register ID information as register history, previously received instruction ID information as payment request history, and previously received request time information as request time history.

[0226] The information management unit 505 judges that the payment request indicated by the instruction information is identical the previous payment request in a case either (i) or (ii) below.

[0227] (i) The register ID information matches the register history, and a difference between the request time information and the request time history is 5 seconds or shorter.

[0228] (ii) The instruction ID information matches the payment request history, and the difference between the request time information and the request time history is 5 seconds or shorter.

[0229] When the information management unit 505 judges that the payment request is identical, the information management unit 505 transmits the payment status information indicating invalid to the cash register 600 via the communication unit 501.

[0230] When the information management unit 505 judges that the payment request is not identical, the information management unit 505 transmits payment instruction information to a balance management unit 506.

[0231] [Balance Management Unit 506]

[0232] The balance management unit 506 stores balance information for the prepaid card functionality.

[0233] The user 50 pays a prepaid amount to the company that runs the shop 60 in advance. The company adds the prepaid amount to the amount indicated by the balance information.

[0234] The balance management unit 506 receives payment information indicating the amount of money to be paid from the cash register 600 via the communication unit 501.

[0235] When the amount indicated by the payment information is equal to or smaller than the amount indicated by the balance information, the balance management unit 506 deducts the amount indicated by the payment information from the amount indicated by the balance information, and transmits the payment status information indicating “paid” to the cash register 600 via the communication unit 501.

[0236] When the amount indicated by the payment information is greater than the amount indicated by the balance information, the balance management unit 506 transmits the payment status information indicating “unpayable” to the cash register 600 via the communication unit 501.

[0237] 2-1-2 Cash Register 600

[0238]FIG. 10 is a block diagram illustrating a structure of the cash register 600. The cash register 600 as hardware is structured by a CPU, a ROM storing a computer program, a RAM, and such. The cash register 600 realizes its function by the CPU operating according to the program stored in the ROM.

[0239] [Barcode Reader 601]

[0240] A barcode reader 601 reads a barcode indicating price information of the article to which the barcode is attached, and then transmits the price information to a payment request unit 603.

[0241] [Calculation Instruction Obtaining Unit 602]

[0242] A calculation instruction obtaining unit 602 is provided with a calculation instruction button, and obtains a calculation instruction when the cashier 70 presses the calculation instruction button to instruct calculation.

[0243] The calculation instruction obtaining unit 602 transmits the calculation instruction to the payment request unit 603 when the calculation instruction is obtained.

[0244] [Payment Request Unit 603]

[0245] The payment request unit 603 receives the price information from the barcode reader 601, and the calculation instruction from the calculation instruction obtaining unit 602.

[0246] When the payment request unit 603 receives the price information for two or more articles from the barcode reader 601, the payment request unit 603 calculates a total amount of prices of the articles upon reception of the calculation instruction, and generates the payment information indicating the calculated total amount. When the payment request unit 603 receives the price information for only one article from the barcode reader 601, the payment request unit 603 generates the payment information indicating the amount that is the same as the amount indicated by the price information.

[0247] When the payment information is generated, the payment request unit 603 further generates instruction ID information for identifying the generated payment information, and transmits an authentication instruction to the authentication unit 605.

[0248] When the authentication completion notification is received from the authentication unit 605, the payment request unit 603 transmits, to the memory card 500 via the communication unit 604, request time information indicating time at which a clock 608 records when the authentication completion notification is received, the payment information, and the instruction ID information.

[0249] [Communication Unit 604]

[0250] A communication unit 604 transmits and receives information wirelessly with the memory card 500.

[0251] [Authentication Unit 605]

[0252] An authentication unit 605, via the communication unit 604, performs mutual authentication and sharing of a key with the memory card 500. Details of the mutual authentication and the sharing of the key will be described later.

[0253] When the mutual authentication and the sharing of the key are successfully completed, the authentication unit 605 transmits an authentication completion notification to the payment request unit 603 and an ID information management unit 607.

[0254] [Encryption Unit 606]

[0255] An encryption unit 606 encrypts and decrypts the information transmitted. When the mutual authentication and the sharing of the key are successfully completed, the encryption unit 606 obtains a session key K from the authentication unit 605.

[0256] After the successful completion of the mutual authentication and the sharing of the key by the authentication unit 605, the communication between the memory card 500 and the cash register 600 is always performed with the information being encrypted. In the transmission of the information to the memory card 500 after the successful completion of the mutual authentication and the sharing of the key, first the encryption unit 606 encrypts the information to be transmitted using the session key K, and then the communication unit 604 transmits the encrypted information. Further, information that the communication unit 604 received from the cash register 600 after the successful completion of the mutual authentication and the sharing of the key is used for an internal process of cash register 600 after the encryption unit 606 decrypts the received information using the session key K.

[0257] [ID Information Management Unit 607]

[0258] The ID information management unit 607 stores unique register ID information for identifying each of the cash register. When the authentication completion notification is received from the authentication unit 605, the ID information management unit 607 transmits the register ID information to the memory card 500 via the communication unit 604.

[0259] [Clock Unit 608]

[0260] The clock unit 608 is a clock to keep time.

[0261] [Display Unit 609]

[0262] A display unit 609 is a liquid crystal display device for displaying such as text.

[0263] The display unit 609 receives the payment status information from the memory card 500 via the communication unit 604, and displays information according to the received payment status information. For example, the display unit 609 displays “Payment Completed” when the received payment status information indicates “paid”, and “Insufficient Funds” when the received payment status information indicates “unpayable”.

[0264] In addition, the display unit 609 may display other information regarding the payment operation, such as an error status indicating communication errors between the memory card, and a bar graph indicating progress of the operation.

[0265] 2-2 Operation

[0266]FIG. 11 is a flowchart showing an entire operation of the payment processing.

[0267] The user 50 carries the memory card 500 and purchases the article in the shop 60 (Step S501).

[0268] The cashier 70 has the barcode reader provided to the cash register 600 read the barcode attached to the article to be purchased. Then, the cashier 70 presses the calculation instruction button provided to the cash register 600.

[0269] The cash register 600 calculates an amount of money to be paid by the user 50 in exchange of the article.

[0270] The user 50 holds the memory card 500 toward the cash register 600.

[0271] The memory card 500 and the cash register 600 perform the mutual authentication and the sharing of the key (Step S502). The operation in Step S502 is substantially the same as the operation in Step S101, other than the cash register 600 and the memory card 500 are used in Step S502 instead of the automatic ticket gate 200 and the memory card 100 in Step S101, respectively. Accordingly, the detail of the operation here is not explained.

[0272] When the authentication in Step S502 is successful, the memory card 500 transmits the card ID information to the cash register 600 (Step S503).

[0273] Also, when the authentication in Step S502 is successful, the cash register 600 transmits the card specification information, the register ID information, the request time information, and the payment information to the memory card 500 (Step S504).

[0274] The memory card 500 judges if the card specification information matches the card ID information (Step S505). When the card specification information does not match the card ID information, it indicates that the card ID information management unit 105 received instruction information for a different memory card, and the memory card 500 transmits the payment status information indicating payment request error to the cash register 600 (Step S506). When the memory card 500 judges that the card specification information matches the card ID information, the operation proceeds to Step S507.

[0275] When the register ID information matches the register, and a difference between the request time information and the request time history is 5 seconds or smaller (Steps S507 and S508), the memory card 500 transmits the payment status information indicating payment request error to the cash register 600 (Step S509). When the instruction ID information matches the payment request history, and the difference between the request time information and the request time history is 5 seconds or smaller (Steps S510 and S511), the memory card 500 transmits the payment status information indicating payment request error to the cash register 600 (Step S512).

[0276] When the amount indicated by the payment information is equal to or smaller than the amount indicated by the balance information (Step S513), the balance management unit 506 deducts the amount indicated by the payment information from the amount indicated by the balance information (Step S515), and transmits the payment status information indicating “paid” to the cash register 600 via the communication unit 501 (Step S516). When the amount indicated by the payment information is greater than the amount indicated by the balance information, the balance management unit 506 transmits the payment status information indicating “unpayable” to the cash register 600 via the communication unit 501 (Step S514).

[0277] The cash register 600 displays based on the payment status information received from the communication unit 501 (Step S517).

3 MODIFIED EXAMPLES

[0278] The present invention is not restricted to the above embodiments, and various modifications may be made within a scope of the technical idea of the present invention.

[0279] (1) In the above embodiments, information such as the valid zone information, valid period information, boarding and destination station information, information regarding date and hour, and amount of money are indicated by integer numbers. However, the above information does not restricted to the integer numbers. In a case of the ID information, it is sufficient if each information is identifiable, and in a case of the information for judging a range, it is sufficient to be able to judge if each information is within or over the range. Accordingly, numbers other than integers, station names, or apparatus names may be used.

[0280] (2) The authentication between the memory card and the instruction apparatus in the above embodiments is performed using the elliptic curve. However, the encryption is not restricted to the above method and a different kind of public key such as RSA encryption may be also used.

[0281] Further, the authentication maybe based on a symmetric-key cryptography in which both sides stores a common key, or any other method with which both sides are mutually authenticated and share the key may be used.

[0282] Moreover, the authentication operation is not restricted to the mutual authentication, and may be a one-way authentication. In other words, the authentication may be either of cases in which only the automatic ticket gate authenticates the memory card, or only the memory card authenticates the automatic ticket gate.

[0283] (3) The use of the memory card is not restricted to a case in which the user takes the train at the boarding station within the zone. It is possible to use the memory card in cases in which (i) the user takes the train at the boarding station that is not within the zone and drops off at the destination station within the zone, (ii) the user takes the train at the boarding station within the zone and drops off at the destination station within the zone, (iii) the user takes the train at the boarding station that is not within the zone, boards the train through the zone, and drops off at the destination station that is not within the zone, and (iv) the user takes the train at the boarding station within the zone and drops of f at the destination station that is not within the zone.

[0284] The memory card adjusts the fare at the destination station using the boarding station information obtained at the boarding station.

[0285] (4) The prepaid functionality of the memory card is not restricted to an occasion when the user exits the destination station. It is possible to decide when the prepaid functionality works according to a chosen fare adjustment system. For example, it is possible that a minimum fare is deducted from the amount recorded in the memory card when boarding, and then the fare is adjusted when the user exits the destination station.

[0286] (5) The memory card does not necessarily have both of the commuter pass and prepaid card functionalities, and may have one of the functionalities. The memory card having only the prepaid card functionality does not need to perform judgment of the zone, and judges the ticket gate information and the time information.

[0287] (6) When using the memory card in shopping, it is not necessary to perform the judging of both the register ID information and the instruction ID information, and it is sufficient if at least one of the above is performed.

[0288] (7) The authentication operation is not need to be performed both at boarding and drop-off. The user may board the train without being authenticated and the authentication is performed only at drop-off. On the other hand, it is also possible that the authentication is performed only when boarding and at drop-off.

[0289] (8) The payment processing device is not restricted to the memory card, and may be a handheld device having substantially the same functions as the memory card.

[0290] The handheld device includes a receiving unit such as a cellular phone and a PDA and a payment processing device such as an IC mounted portable semiconductor memory, and the receiving unit communicates with the instruction apparatus and the payment processing device performs the operations that the memory card performs other than communication.

[0291] Further, the handheld device may also be such as a cellular phone and a PDA having substantially the same functions as the memory card.

[0292] (9) It is also possible that the memory card explained in the first embodiment does not include the ticket gate management unit. In this case, the pass information management unit may judge, based on the stored station information, if the payment request is identical with the previous payment request from the same ticket gate.

[0293] Further, it is also possible that the memory card does not include the ticket gate management unit, and only the time information is managed by the time information management unit 107.

[0294] (10) The memory card does not necessarily include all of the functions explained in the embodiments, and it may be any structure with a function for reducing incorrect collection.

[0295] (11) The time information does not necessarily have to be kept to the second, and it may be kept by hour, day, or other time unit.

[0296] In addition, the valid period information for the commuter pass stored in the memory card and the gate time information transmitted from the ticket gate do not necessarily have the same format. For example, it is possible that the valid period information for the commuter pass stored in the memory card is indicated by day, and the gate time information transmitted from the ticket gate is indicated to seconds, and vice versa.

[0297] (12) As a judging method based on the valid period information, it is possible to judge between “in-period” and “out-period” by comparing the valid period information and one of boarding time and drop-off time.

[0298] (13) Although the above explanations are given taking the fare adjustment and settlement as examples, it is also possible to use the present invention in a point adjustment system for adding and removing an amount of points.

[0299] The points referred to here is used in such a system in which the user earns a certain amount of points according to a payment made for a service, and the user exchanges the earned points later on, with an item having a corresponding value to the amount of points the user wishes to exchange.

[0300] The system for adding and removing the amount of points is structured by an instruction apparatus and a value holding system.

[0301] For example, the instruction apparatus is a cash register at supermarkets, and the value holding system is a system including a memory card and a handheld device that records the amount of points that is added or removed in the memory card. The instruction apparatus transmits a point adjustment request to the value holding system. The value holding system judges if the point adjustment request is valid, and not identical for example. The same method of judgment as explained in the above embodiments is used. The value holding system stores point information indicating the amount of the points that have been added. When judging that the request is valid, the value holding system adjusts the points stored in the memory card by adding or removing the requested amount of points to or from the amount of points indicated by the point information. When judging that the request is not valid, the value holding system rejects the request.

[0302] As indicated in the above, the wordings “point adjustment” here are used as a concept that includes both addition and removing of the amount of points. Specifically, when the instruction apparatus transmits a request of adding points, the value holding system adjusts the amount of points by adding the amount indicated by the request unless the request is invalid. When the instruction apparatus transmits a request of removing points, the value holding system adjusts the points by removing the amount of points indicated by the request unless the request is invalid.

[0303] (14) The present invention may also be a method that includes steps explained in the embodiments. The present invention may also be a computer program that realized the method when executed by a computer, and may also be digital signals made of the computer programs.

[0304] Further, the present invention may also be a computer readable storage medium, such as a flexible disc, a hard disk, a CD-ROM, an MO, a DVD, a DVD-ROM, a DVD-RAM, a BD (Blue-ray Disc), and a semiconductor memory, that stores the program or the digital signals. The present invention may also be the program or the digital signals stored in the computer readable storage medium.

[0305] In addition, the present invention can also be the computer program or the digital signals that are transmitted via a telecommunication line, a wireless connection, a cable communication line, and the network represented by the Internet, a data and audio broadcast, and the like.

[0306] Further, the present invention may also be a computer system comprising a micro processor and a memory, in which the memory stores the computer program and the micro processor operates according to the program.

[0307] Moreover, the present invention may also be such that the computer program or the digital signals that are transmitted to an independent computer system, via the storage medium that stores the computer program or the digital signals, or via the network, so as to be executed in the independent computer system.

[0308] Although the present invention has been fully described by way of examples with reference to the accompanying drawings, it is to be noted that various changes and modifications will be apparent to those skilled in the art. Therefore, unless otherwise such changes and modifications depart from the scope of the present invention, they should be construed as being included therein. 

What is claimed is:
 1. A value holding system, comprising: a receiving unit operable to receive an instruction to add or remove a value relating to a payment; a judging unit operable to judge whether the instruction is identical with an instruction that has been previously received; and a rejecting unit operable to reject the instruction when judged that the instruction is identical with the previous instruction.
 2. A value holding system according to claim 1, wherein the value is equivalent to an amount of money, and the receiving unit receives, as the instruction, instruction information that indicates adding or removing the amount of money shown by the value.
 3. A value holding system according to claim 2, wherein the judging unit (i) stores a piece of instruction information last received by the receiving unit, and (ii) judges whether the instruction is identical with the previous instruction, using the stored piece of instruction information and the currently received piece of instruction information.
 4. A value holding system according to claim 3, wherein the judging unit judges that the instruction is identical with the previous instruction, when the stored piece of instruction information matches the currently received piece of instruction information.
 5. A value holding system according to claim 3, wherein each instruction information contains an apparatus ID identifying an instruction apparatus, and the judging unit judges that the instruction is identical with the previous instruction, when an apparatus ID contained in the stored piece of instruction information matches an apparatus ID contained in the currently received piece of instruction information.
 6. A value holding system according to claim 3, wherein each instruction information contains a location ID identifying a location of an external instruction apparatus, and the judging unit judges that the instruction is identical with the previous instruction, when a location ID contained in the stored piece of instruction information matches a location ID contained in the currently received piece of instruction information.
 7. A value holding system according to claim 3, wherein each instruction information contains an instruction ID identifying the instruction information, the judging unit judges that the instruction is identical with the previous instruction, when an instruction ID contained in the stored piece of instruction information matches an instruction ID contained in the currently received piece of instruction information.
 8. A value holding system according to claim 3, wherein the judging unit judges that the instruction is identical with the previous instruction, when a difference between the stored piece of instruction information and currently received piece of instruction information is within a predetermined range.
 9. A value holding system according to claim 3, wherein each instruction information contains time information indicating a time relating to the instruction, the judging unit judges that the instruction is identical with the previous instruction, when a difference between a time indicated by time information in the stored piece of instruction information and a time indicated by time information in the currently received piece of instruction information is within a predetermined range.
 10. A value holding system according to claim 3 structured by a handheld device and a memory card, wherein the handheld device includes the receiving unit, and the memory card includes the judging unit and the rejecting unit.
 11. A value holding system according to claim 3, wherein the system is a memory card.
 12. A value holding system according to claim 3, wherein the system is a handheld device.
 13. A method realized by a value holding system including a receiving unit, a judging unit, and a rejecting unit, the method comprising: a receiving step in which the receiving unit receives an instruction to add or remove a value relating to a payment; a judging step in which the judging unit judges whether the instruction has been previously received; and a rejecting step in which the rejecting unit rejects the instruction when judged that the instruction has been previously received.
 14. A program applied to a value holding system including a receiving unit, a judging unit, and a rejecting unit, the program comprising: a receiving step in which the receiving unit receives an instruction to add or remove a value relating to a payment; a judging step in which the judging unit judges whether the instruction has been previously received; and a rejecting step in which the rejecting unit rejects the instruction when judged that the instruction has been previously received.
 15. A transaction system structured by an instruction apparatus and a value holding system, the value holding system comprising: a receiving unit operable to receive an instruction to add or remove a value relating to a payment; a judging unit operable to judge whether the instruction is identical with an instruction that has been previously received; and a rejecting unit operable to reject the instruction when judged that the instruction is identical with the previous instruction.
 16. A transaction system according to claim 15, wherein the value holding system is a memory card.
 17. A transaction system according to claim 15, wherein the value holding system is a handheld device.
 18. A transaction system according to claim 15, wherein the value holding system is structured by a handheld device and a memory card, the handheld device including the receiving unit, and the memory card including the judging unit and the rejecting unit.
 19. A value holding system according to claim 1, wherein, the value is equivalent to an amount of points, and the receiving unit receives, as the instruction, instruction information that indicates adding or removing the amount of points shown by the value. 